home *** CD-ROM | disk | FTP | other *** search
/ Emulator Universe CD / emulatoruniversecd1998.iso / Atari / ROMs / PC ATARI.TXT < prev    next >
Encoding:
Text File  |  1997-08-20  |  78.6 KB  |  1,598 lines

  1.  
  2.  
  3.  
  4.  
  5.  
  6.  
  7.  
  8.  
  9.  
  10.  
  11.  
  12.                         PC Atari Emulator
  13.  
  14.                            Version 2.0
  15.  
  16.                           Users Manual
  17.  
  18.  
  19.  
  20.  
  21.  
  22.  
  23.  
  24.  
  25.  
  26.  
  27.                                      John Dullea (jxd230@psu.edu)
  28.                                                      August, 1997
  29.                                                                  
  30. =================================================================
  31. 1    What is PCAE?
  32.  
  33. The PC Atari Emulator, or PCAE, is an MS-DOS program designed  to
  34. emulate  the  famous  Atari 2600 Video Computer  System  on  PC's
  35. compatible  with  the Intel 80486 CPU or better. It  accomplishes
  36. this with an emulation engine that is written almost entirely  in
  37. assembly language, with extra features written in Borland  Pascal
  38. 7.0 for DOS.
  39.  
  40. System Requirements
  41.  
  42. OS:       MS-DOS,  though it will run from within a  Windows  DOS
  43.           prompt. Some users have successfully run it from within
  44.           an  OS/2  DOS  prompt by setting the "Allow  access  to
  45.           hardware timer" flag to ON.
  46.  
  47. CPU:      Intel  80486  or  greater, for  the  BSWAP  instruction
  48.           (though a Pentium is highly recommended for performance
  49.           purposes)
  50.  
  51. RAM:      540K  free  low DOS memory (though 590K or  greater  is
  52.           strongly recommended). Also, at least 2Mb of XMS memory
  53.           is  needed  to  store sound samples (setting  a  larger
  54.           sound buffer requires more XMS memory)
  55.  
  56. Other:    A mouse is  required for single-player paddle emulation
  57.           A 4-button joystick is strongly recommended, ESPECIALLY
  58.           a   Gravis   GamePad.   Two  joysticks   are   strongly
  59.           recommended  for two-player games To use  joysticks  to
  60.           emulate  paddles  two and three, analog  joysticks  are
  61.           required.
  62.           A  special home-built board is necessary for connecting
  63.           real Atari controllers to the PC.
  64.           
  65. Sound:    A   SoundBlaster  or  100%  compatible  sound  card  is
  66.           required  for sound support. To get perfect sound  from
  67.           within  a  Windows DOS prompt the sound  card  must  be
  68.           compatible  with Sound Blasters utilizing DSP  versions
  69.           2.00 or greater.
  70.  
  71. Features
  72.  
  73. o    Very fast emulation due to the Pentium-optimized assembly
  74.      implementation
  75. o    Full collision checking
  76. o    One paddle is emulated using the mouse, and two other
  77.      paddles can be emulated using analog joysticks. The paddle
  78.      assignments can be rotated from the main menu.
  79. o    Emulates the Atari Video Touch Pad (for Star Raiders) and
  80.      Atari Keyboard Controllers via the keyboard.
  81. o    Emulates Atari Indy 500 Driving Controllers (for Indy 500)
  82.      and CBS Booster-Grip (for Omega Race) via the keyboard or
  83.      joysticks
  84. o    Support for two joysticks (four-button joysticks can control
  85.      select, reset, and both players' fire buttons in all games
  86.      except CBS 12k games)
  87. o    Built-in menu allows easy selection of games
  88. o    Support for a game profile file that contains all the
  89.      cartridge types and controller settings for every game in
  90.      your library
  91. o    On-line help is available in the menu system, integrated
  92.      debugger, and while playing games
  93. o    Built in interactive debugger that supports bank-switched
  94.      images
  95. o    Built-in disassmebler for images 4k or smaller, as well as
  96.      many 8k, 16k, Super-Chip, and CBS games.
  97. o    Support for Atari 8k, Atari 16k, Super-chip, Parker
  98.      Brothers, CBS RAM-Plus, TigerVision, M-Network, and Pitfall
  99.      II bank switched cartridges
  100. o    Supports 64k cartridges containing 32 independent 2k games
  101.      (32-in-1 games)
  102. o    Supports 64k Brazilian Megaboy cartridge
  103. o    Supports extended Super-chip and TigerVision bankswitching
  104.      specifications
  105. o    Support of Starpath Supercharger single-load and multi-load
  106.      games
  107. o    Sound emulation using Ron Fries' TIA Emulation Library on
  108.      100% Sound Blaster-compatible sound cards
  109. o    Emulation speed can be slowed down to a user-selectable
  110.      number of frames per second for especially fast computers
  111. o    The sound buffer size can be increased for better sound
  112.      quality or decreased for faster emulation
  113. o    The sound playback rate can be varied for compatibility
  114.      with certain sound cards
  115. o    Includes two versions of the emulator, one that runs in
  116.      standard 320x200x256 VGA mode and one that uses a non-
  117.      standard 160x200x256 mode for greater speed (might not be
  118.      compatible with all VGA cards and/or monitors)
  119. o    Each executable supports an optional extended VGA resolution
  120.      for games which utilize more than 200 scan lines (might not
  121.      be compatible with all VGA cards and/or monitors)
  122. o    Support for connecting real Atari 2600 controllers to a PC
  123.      using a home-built board that connects to a PC joystick port
  124.      and bidirectional parallel port
  125. o    Users with sound cards that are 100% compatible with Sound
  126.      Blaster cards with DSP versions 2.00 and greater will enjoy
  127.      improved sound in DOS due to auto-initializing DMA. With
  128.      such cards, the sound from within Windows 95 should be of
  129.      the same quality as from within DOS.
  130. o    Supports the PAL graphics palette in addition to the NTSC
  131.      palette
  132. o    Allows joystick buttons to be remapped from the main menu
  133. o    Built-in vertical autocentering for different games, which
  134.      can be disabled by the user
  135.  
  136. Emulation Speed
  137.  
  138. The  emulated speed of games run on the software varies  by  game
  139. and  system type. I have found that a Pentium-90 system  can  run
  140. most  games  at  a slightly higher speed than the original  Atari
  141. console,  but  there  are a few exceptions  for  which  a  faster
  142. computer might help. I have received e-mails claiming that  i486-
  143. 120  computers  can  just  reach 100% emulated  speed  using  the
  144. emulator.
  145.  
  146. =================================================================
  147. 2       Setting It Up
  148.  
  149. Installing the Software
  150.  
  151. Most  likely you will acquire the emulator via a ZIP archive file
  152. that  was either downloaded from somewhere or placed on a CD-ROM.
  153. The  first thing to do is to create a new directory in  which  to
  154. place  all the files contained in the archive file. For  example,
  155. DOS users would type:
  156.  
  157.      C> CD\               move to the root directory
  158.      C> MD PCAE           create the new directory
  159.      C> CD\PCAE           move to the new directory
  160.  
  161. The  next  thing to do is to place all the files in  the  archive
  162. file  into  the  new  directory. There are a number  of  programs
  163. available for extracting a ZIP file, such as PKWare's PKUNZIP for
  164. MS-DOS, or the shareware WINZIP for MS-Windows. Symantec's Norton
  165. Navigator  File  Manager for Windows 95 is also  a  good  choice.
  166. Using   whichever  method  you  choose,  extract  all  the  files
  167. contained  in  the  ZIP archive into the new directory  you  just
  168. created.
  169.  
  170. Setting Up Sound Support
  171.  
  172. PCAE  supports sound emulation of the Atari 2600 using 100% Sound
  173. Blaster-compatible  sound  cards.  Although   using   "true-blue"
  174. Creative Labs hardware is strongly recommended, there are a great
  175. many  sound cards that will work with the emulator. In all cases,
  176. if  you  intend  to  turn on sound support in the  emulator,  you
  177. should  first check to see if your sound card is compatible  with
  178. the emulator and that it is properly configured.
  179.  
  180. PCAE supports 100% Sound Blaster-compatible sound cards using IRQ
  181. settings in the range 0 to 15 and 8-bit DMA settings in the range
  182. 0  to 3. To my knowledge, all SB-compatible sound cards use an 8-
  183. bit DMA setting in the range 0 to 3, but any that do not will not
  184. work  with  the  emulator.  To find out  or  change  your  card's
  185. settings,  you  should  read  the installation  manual  that  was
  186. included  with your hardware. Most sound cards (especially  those
  187. from  Creative Labs) come with a test program that will tell  you
  188. the  current  IRQ and DMA settings of your card. Another  way  to
  189. possibly  find out the settings is to check them from within  the
  190. Windows 3.x or Windows 95 Control Panel.
  191.  
  192. If  you have verified that your sound card's IRQ and DMA settings
  193. are  compatible  with PCAE, the next step is to ensure  that  the
  194. BLASTER  environment  string is properly  set.  This  environment
  195. string  is  the  mechanism by which PCAE gets your  sound  card's
  196. settings, and is absolutely necessary for sound emulation to work
  197. properly;  otherwise,  lockups  or  crashes  will  likely  occur.
  198. Usually  this  line  is set automatically by  your  sound  card's
  199. installation software, but this is not always the case.  You  can
  200. check to see if it is set by typing "SET" from the MS-DOS prompt:
  201.  
  202. Example:
  203.  
  204.      C> SET
  205.      TEMP=C:\WINDOWS\TEMP
  206.      winbootdir=C:\WINDOWS
  207.      SOUND=F:\SBPRO
  208.      windir=C:\WINDOWS
  209.      COMSPEC=C:\COMMAND.COM
  210.      PATH=C:\;C:\DOS;C:\WINDOWS;C:\WINDOWS\COMMAND;.
  211.           .
  212.           .
  213.           .
  214.      BLASTER=A220 I7 D1   <-This is the line you're interested in
  215.  
  216. The basic format of the BLASTER environment string is as follows:
  217. There  should be a field in the form A#, where the number is  the
  218. sound  card's  address in hexadecimal. For example,  my  Creative
  219. Labs  Sound Blaster Pro is at address 220h. Second, there  should
  220. be  a  field  in the form I#, where # is the IRQ setting  of  the
  221. card. Finally, there should be a field in the form D#, where # is
  222. the  8-bit  DMA  setting of the card. More  advanced  cards  will
  223. probably have additional fields on the line, for such features as
  224. 16-bit DMA and MIDI ports.
  225.  
  226. If this line is present in your environment string list, then, as
  227. long as the numbers match the actual hardware settings, there  is
  228. nothing more to check regarding your sound hardware. However,  if
  229. the  line is not present, you will have to see to it that one  is
  230. present before running the emulator. This can be done manually or
  231. it  can be added to a batch file, such as AUTOEXEC.BAT. In either
  232. case, the process of adding or changing an environment string  is
  233. a simple DOS command:
  234.  
  235.       C> SET BLASTER=A220 I7 D1 <-Ex. of setting the BLASTER line
  236.  
  237. All  you  do is type the DOS "SET" command as above but  add  the
  238. line to be added after it. "BLASTER=" identifies the name of  the
  239. environment string and "A220 I7 D1" is the environment string  it
  240. will refer to.
  241.  
  242. Please note that environment strings from SET commands do not use
  243. up  any  low DOS memory in the same manner as TSR (terminate-and-
  244. stay-resident)  files,  but they do take  up  environment  string
  245. space.  Usually the largest environment string you will  have  is
  246. your  PATH  statement, which is usually set in  the  AUTOEXEC.BAT
  247. file. If you look in this file, you will probably see lines  that
  248. begin  with  "PATH" instead of beginning with "SET". Because  the
  249. PATH  environment  string  is used by  everyone,  the  people  at
  250. Microsoft  included a special command called PATH that  sets  the
  251. PATH  environment  string. Using "SET PATH=." instead  of  "PATH"
  252. would  yield the same result. At any rate, if you do not  have  a
  253. BLASTER environment string and try to add one, you might run  out
  254. of   environment  string  space  if  you  have  a  lot  of  other
  255. environment  strings or a few large ones. You can check  this  by
  256. typing  "SET"  after setting the BLASTER environment  string  and
  257. checking  to  see if the entire string is present.  If  it  isn't
  258. there  or  is truncated, you might have to either (1) shorten  or
  259. eliminate another environment string (such as your path)  or  (2)
  260. increase  the amount of environment string space. The method  for
  261. increasing environment string space varies widely with  operating
  262. systems and is beyond the scope of this document. The only method
  263. with which I am familiar is the "/E:xxxx" command line option  in
  264. MS-DOS  COMMAND.COM, which would be specified  in  CONFIG.SYS  as
  265. follows:
  266.  
  267.      SHELL=COMMAND.COM /P /E:1024
  268.  
  269. This  sets the environment string area to 1024 bytes upon bootup.
  270. The /P option is necessary to tell DOS that COMMAND.COM is to  be
  271. loaded  permanently.  This should work for  those  using  MS-DOS,
  272. Windows 3.x, or those running PCAE after restarting Windows 95 in
  273. MS-DOS mode. For Windows 95 MS-DOS prompts, you might not have to
  274. change  the  setting since it has an "Auto" feature,  but  it  is
  275. available  by  exploring to the MS-DOS prompt, right-clicking  on
  276. it,  and  selecting "Properties". The initial environment  string
  277. area size can then be changed by clicking on the "Memory" tab and
  278. changing the "Initial environment" setting.
  279.  
  280. Note:  Several  users with Pro Audio Spectrum  sound  cards  have
  281. expressed  problems  getting the sound to  operate  properly.  By
  282. default, the emulator plays sound at a rate of 31.4 kHz which may
  283. be  too fast for some cards. There is a feature in the popup menu
  284. that  allows  the playback rate to be set to a lower value  which
  285. hopefully  should  help  matters (to  be  discussed  in  a  later
  286. section).
  287.  
  288. Once  your BLASTER environment string is set properly, you  might
  289. want to check to see if your sound card's mixer settings (if any)
  290. are  set  properly. For DOS users, this usually involves a  mixer
  291. utility  that comes with your sound card. For example,  my  Sound
  292. Blaster  16 SCSI-2 has two programs, SB16SET (which is loaded  in
  293. my AUTOEXEC.BAT) and SB16MIX, which is a TSR that lets me control
  294. the  mixer settings. This is important because PCAE uses  digital
  295. sound output for the majority of Atari 2600 sound emulation,  but
  296. uses  FM  sound output for the music in Pitfall II: Lost Caverns.
  297. For  the  sound to be properly balanced, the mixer  settings  for
  298. digital  and  FM  sound output should be of equal value.  Windows
  299. users will probably have similar utilities for their sound cards,
  300. and  Windows  95  users  can try double-clicking  on  the  little
  301. speaker icon in the system tray at the bottom right. This  should
  302. bring  up  a  mixer  window that enables control  over  different
  303. settings.  FM  sound output is usually controlled by  the  "Midi"
  304. slider, and digital output by the "Wave" slider. Be sure also  to
  305. pay  attention  to  the "Master" slider to ensure  that  you  get
  306. sound.
  307.  
  308. The  final  issue  regarding sound setup is your  general  memory
  309. configuration. PCAE pre-calculates sound samples upon startup and
  310. stores  them in XMS memory. For buffer sizes of about  4k,  about
  311. 2Mb of XMS is required. Setting a larger sound buffer size causes
  312. the  emulator to recalculate the sound samples for the new buffer
  313. size and requires more XMS memory. Likewise, smaller buffer sizes
  314. relax the XMS requirement. In any case, you will need to have  an
  315. XMS memory manager loaded to run the emulator with sound support.
  316. Managers like HIMEM.SYS provide XMS support and are adequate  for
  317. this purpose.
  318.  
  319. To determine whether you have XMS memory, type "MEM" from the DOS
  320. prompt, which is a command that comes with MS-DOS and Windows 95.
  321. It  will display a memory summary that will tell you how much XMS
  322. memory, if any, you have available. If none is present, you might
  323. have to load an XMS memory manager. The procedure is outside  the
  324. scope  of this document, but for those with MS-DOS, Windows  3.x,
  325. or  those running PCAE after restarting Windows 95 in MS-DOS mode
  326. (NOT  merely  an  MS-DOS prompt) it usually  involves  loading  a
  327. driver  called HIMEM.SYS into the CONFIG.SYS file  on  your  boot
  328. drive:
  329.  
  330.      DEVICE=HIMEM.SYS
  331.  
  332. Your  configuration  might  vary from  this,  depending  on  your
  333. operating  system  and the location of your XMS  memory  manager.
  334. Typical  directories  in  which it  might  reside  are  \DOS  and
  335. \WINDOWS. If you are unsure how to load such a driver, you should
  336. contact the manufacturer of your operating system.
  337.  
  338. The amount of XMS memory available in a Windows 95 DOS prompt can
  339. be  altered by exploring to the MS-DOS prompt, right-clicking  on
  340. it,  and  selecting "Properties". Then, clicking on the  "Memory"
  341. tab will allow configuration of the available memory.
  342.  
  343. Note for Windows Users
  344.  
  345. PCAE  requires  that  all its support files reside  in  the  same
  346. directory, and that they reside in the same directory from  which
  347. the  program is run. When setting up a Windows 3.1 or Windows  95
  348. shortcut,  be sure to specify the PCAE directory as  the  one  in
  349. which  the  program should start. Leaving this entry  blank  will
  350. likely  cause the program to abort with an error since it  always
  351. looks  in  the current directory for its support files and  might
  352. not find them.
  353.  
  354. =================================================================
  355. 3       Playing Games
  356.  
  357. Once  the  software  has  been set  up  and  the  sound  card  is
  358. configured properly, you are ready to try the emulator  with  any
  359. games  that  you  own.  PCAE requires that  all  games  have  the
  360. extension  .BIN. Games can be run in two ways: from  the  command
  361. line using arguments, or using the built-in menu. The easiest way
  362. to  run  games  is  to place all of them in the  same  directory,
  363. preferably though not necessarily in the same directory  as  PCAE
  364. and use the built-in menu. When trying the emulator for the first
  365. time,  it  is  recommended  you first  use  PCAE.EXE  instead  of
  366. PCAE160.EXE, since PCAE.EXE is more compatible with most systems.
  367. In  this  way the non-standard nature of PCAE160's special  video
  368. mode can be ruled out in the event of problems.
  369.  
  370. The Command Line
  371.  
  372. Although not necessary for most users, the command line  has  the
  373. benefit of allowing PCAE to be run from within other game  shells
  374. or  allowing  individual  games to have  Windows  shortcuts.  The
  375. format is as follows:
  376.  
  377. ATARI [path |
  378.    file [BANK | BANK16 | BANKA | BANKM | BANKP | BANKC | BANKSC |
  379.          BANKSP | BANKT | BANK2 | BANK3 | BANKG | PROFILE]
  380.         [32IN1NUMxx]
  381.         [DEBUG]
  382.         [DISASM]
  383.         [FRAMExx]
  384.         [KB | INDY500 | VTP | PADDLE]
  385.  
  386. path           path to a .BIN game directory, e.g. C:\CARTS
  387. file           filename of an individual game
  388.  
  389. BANK           needed for Atari 8k bankswitched games
  390. BANK16         needed for Atari 16k bankswitched games
  391. BANKA          needed for Activision Decathlon and Robot Tank
  392. BANKM          needed for M-Network bankswitched games
  393. BANKP          needed for 8k Parker Brothers bankswitched games
  394. BANKT          needed for 8k or larger TigerVision bankswitched
  395.                games
  396. BANKC          needed for 12k CBS RAM-Plus bankswitched games
  397. BANKSC         needed for Atari 16k or larger Super-Chip
  398.                bankswitched games
  399. BANKSP         needed for Starpath SuperCharger games
  400. BANK2          needed for Pitfall II: Lost Caverns
  401. BANK3          needed for 32-in-1 games
  402. BANKG          needed for Brazilian Megaboy game
  403. PROFILE        Use profile file for bankswitching and controller
  404.                information
  405.  
  406. DEBUG          Activate built-in integrated debugger
  407. DISASM         Disassemble a 4k or smaller game to LISTING.ASM
  408. FRAMExx        Limit the number of frames per second to xx for
  409.                fast computers (or 0 for no limit)
  410. KB             Emulate Atari Keyboard Controllers
  411. INDY500        Emulate Atari Indy 500 Driving Controllers
  412. VTP            Emulate Atari Video Touch Pad
  413. PADDLE         Emulate Atari paddles
  414. 32IN1NUMxx     Play 2k game xx (0-31) from 32-in-1 game
  415.  
  416. Note  that  the path argument is not used with any other  command
  417. line  argument; it is intended for using the built-in  menu  with
  418. game  files  that  are not located in the same directory  as  the
  419. emulator. Some examples of command line usage are:
  420.  
  421.      C> PCAE D:
  422.      C> PCAE D:\GAMES
  423.      C> PCAE PACMAN.BIN
  424.      C> PCAE DIGDUG.BIN BANKSC
  425.      C> PCAE COMBAT.BIN DISASM
  426.      C> PCAE OMEGARAC.BIN BANKC
  427.      C> PCAE ROBOTANK.BIN BANKA DEBUG
  428.      C> PCAE BNJ.BIN BANKM DISASM DEBUG
  429.      C> PCAE INDY500.BIN INDY500 FRAME60
  430.  
  431. Generally it is cumbersome for most users to use the command line
  432. in  any  but  the  first  example  unless  writing  shortcuts  to
  433. individual games or writing a game shell.
  434.  
  435. The Main Menu
  436.  
  437. The  main menu is the area from which most games will be run.  It
  438. provides for easy selection of any game in the directory, as well
  439. as  configuration of the emulator. In addition, the menu  is  the
  440. area from which the online help reference can be reached.
  441.  
  442. The menu consists of a text display showing all the .BIN and .PAL
  443. files detected in the directory. They will be displayed in color-
  444. coded  fashion,  with  different colors denoting  different  file
  445. sizes:
  446.  
  447.      gray           2k and 4k
  448.      white          8k
  449.      yellow         16k
  450.      red            8,448-byte (or multiples thereof) Starpath
  451.                     Supercharger games
  452.      green          10,495-byte Pitfall II: Lost Caverns game
  453.      black          all others
  454.  
  455. Files can be selected by using the cursor keys or joystick  1  to
  456. move the highlight bar to the desired file. The file size at  the
  457. top will change to reflect the selected file.
  458.  
  459. Once  a  desired  file is selected, it can be played  by  hitting
  460. either  the Enter key or joystick 1's button 1 if it's color  was
  461. gray or red. If it was any other color and you are not using  the
  462. profile  feature, a special bankswitching key might  have  to  be
  463. pressed instead, depending on the type of game that it is:
  464.  
  465.      If game profile has been generated      Enter / joy1 but1
  466.      Standard 8k
  467.        (not any other bankswitched scheme)   Enter / joy1 but1
  468.      Standard 16k 
  469.        (not any other bankswitched scheme)   Enter / joy1 but1
  470.      12k  CBS RAM-Plus                       Enter / joy1 but1
  471.      16k or larger SuperChip                 R
  472.      8k Parker Brothers                      P
  473.      16k M-Network                           M
  474.      Activision Decathlon or Robot Tank      A
  475.      8k or larger TigerVision                T
  476.      Pitfall II: Lost Caverns                2
  477.      32-in-1 game                            3
  478.      Brazilian Megaboy game                  G
  479.  
  480. Games  that  have  the .BIN extension will use  the  NTSC  screen
  481. palette by default; games with extension .PAL will default to the
  482. PAL screen palette.
  483.  
  484. A  note  about  Pitfall II: Lost Caverns: this game,  unlike  all
  485. other  Atari 2600 games, has a special chip that contains  2k  of
  486. extra data in addition to the standard 8k. It also contains three
  487. random   number  generators  and  a  three-channel  square   wave
  488. generator.  To  play Pitfall II on PCAE, the  ROM  file  must  be
  489. 10,495  bytes in size. The first 8k must be the standard 8k  dump
  490. of  the main ROM chip; the next 2048 bytes must consist of the 2k
  491. of extra data in the special chip, and the last 255 bytes must be
  492. read  from one of the random number generators (the three  random
  493. number generators each have a 255-byte cycle and produce the same
  494. values).  Such a ROM file encompasses all the data  that  can  be
  495. generated  from the cartridge; PCAE is designed to  automatically
  496. read  whichever part is appropriate, depending on  the  addresses
  497. accessed.
  498.  
  499. The Configuration Popup Menu
  500.  
  501. In  addition  to  the keys that are dedicated to  playing  games,
  502. there   are   several  functions  that  affect   PCAE's   general
  503. configuration.  These are generally related  to  the  controllers
  504. that   are   to   be  emulated,  and  the  sound   and   joystick
  505. configuration. They are accessible by pressing F10 from the  main
  506. menu, which will pop-up the configuration menu. A description  of
  507. the available functions is as follows:
  508.  
  509.      Set frames per second:  Limit the emulator to display a
  510.                          specific number of frames per second
  511.                          (e.g. 60 fps)
  512.      Build game profile:  Automatically generate PCAE.PRO, the
  513.                          game profile file
  514.      Use standard controllers:  Set the program to emulate Atari
  515.                          joystick controllers
  516.      Use paddle controllers:  Set the program to emulate Atari
  517.                          paddle controllers
  518.      Use keyboard controllers:  Set the program to emulate Atari
  519.                          Keyboard Controllers
  520.      Use Indy 500 controllers:  Set the program to emulate Atari
  521.                          Indy 500 Driving Controllers (used with
  522.                          Indy 500)
  523.      Use Video Touch Pad:  Set the program to emulate Atari Video
  524.                          Touch Pad (used with Star Raiders)
  525.      Change paddle assignments:  Changes the paddle emulated by
  526.                          the mouse. The joysticks will always
  527.                          emulate the first two available paddles
  528.                          after the mouse's paddle has been
  529.                          selected.
  530.      Use keyboard:       Disable PC joysticks and use the
  531.                          keyboard only
  532.      Calibrate and use joystick(s):  Enable 1 or 2 PC joysticks
  533.                          and calibrate them
  534.      Remap joystick buttons:  Display a pop-up menu that allows
  535.                          the joystick buttons to be mapped to
  536.                          player 1 fire, player 2 fire, select,
  537.                          and reset functions
  538.      Toggle using real controllers: Instead of using PC joysticks
  539.                          or the keyboard, this will tell the
  540.                          emulator to expect real Atari
  541.                          controllers plugged into a specific home-
  542.                          built board plugged into the PC joystick
  543.                          port and a bidirectional parallel port
  544.      Set parallel port:  Sets the port number of the parallel
  545.                          port for using real Atari controllers
  546.      Calibrate paddles:  When using real Atari paddles plugged
  547.                          into the board, select this option to
  548.                          calibrate the paddles for the speed of
  549.                          your PC
  550.      Toggle debugger:    Toggle using the integrated debugger,
  551.                          which will be invoked when a game is
  552.                          started
  553.      Toggle sound:       Toggle sound emulation on or off
  554.      Set sound options:  Adjust the sound buffer size and
  555.                          playback rate
  556.      Toggle extended VGA mode:  Toggle extended VGA mode (not
  557.                          fully active when using the integrated
  558.                          debugger).  PCAE.EXE can optionally
  559.                          display 204 scan lines and PCAE160.EXE
  560.                          can optionally display either 215 or
  561.                          250 scan lines.
  562.  
  563. The  Atari 2600 display specification defines a standard viewable
  564. area  of 160 pixels by 192 scan lines, which was expected to work
  565. on  all  television sets. However, there are a  few  games  which
  566. utilize  more  than this, in fact more than 200 scan  lines.  For
  567. this  reason,  each executable has the ability of being  switched
  568. into a non-standard VGA mode that supports extra scan lines.  The
  569. standard  executable,  PCAE.EXE, can  be  switched  into  a  non-
  570. standard 320x204x256 VGA mode, while PCAE160.EXE will switch from
  571. the  160x200x256  mode to 160x215x256. When  this  is  done,  all
  572. subsequent games will run in the extended VGA mode.
  573.  
  574. In  addition to the above commands, the F1 key can be pressed  to
  575. display  summary  screens of the command  line  syntax  and  menu
  576. commands.
  577.  
  578. The Game Profile File
  579.  
  580. The  game profile file, PCAE.PRO, is a text file the emulator can
  581. automatically generate that contains the game type and controller
  582. information  for each file in the game directory. It is  intended
  583. to  eliminate  the  need  to  memorize  which  bankswitching  and
  584. controller  keys  are associated with which  game,  allowing  all
  585. games to be played with the Enter key or joystick 1 button 1.  It
  586. is  supplemented  by a user-modifiable known game  profile  file,
  587. PCAE.KNW,   which  contains  filenames,  game  type  codes,   and
  588. controller  codes  for  all  games  that  are  not  automatically
  589. detected by the profile creation process. All Parker Brothers, M-
  590. Network,  and TigerVision games cannot be automatically  detected
  591. by  the  profile creation process, and must be referenced in  the
  592. known  game  profile file. In addition, there may be other  games
  593. which  are not correctly identified and must be included in  this
  594. file.  The  emulator  has  no  way  of  autodetecting  controller
  595. information  for  each  game, and will thus  give  each  game  an
  596. "unknown  type"  controller  code.  This  will  result  in  games
  597. defaulting  to joystick emulation. It is therefore  necessary  to
  598. add  entries  in  the PCAE.KNW file for games  the  use  paddles,
  599. Keyboard Controllers, etc.
  600.  
  601. Note:  After  changing  the PCAE.KNW file,  it  is  necessary  to
  602. regenerate  the profile file (PCAE.PRO) for the changes  to  take
  603. effect.
  604.  
  605. Each line of text in the known game profile file can be either  a
  606. valid  game  reference,  a remark, or a blank  line.  Valid  game
  607. reference lines should contain the filename of a particular game,
  608. one  or more spaces, a two-letter code describing the game  type,
  609. one  or  more  spaces,  and  a  two-letter  code  describing  the
  610. controller  information. Remarks are not allowed  on  valid  game
  611. reference  lines. All remark lines should begin with a  semicolon
  612. (;)  as  the  first character (no leading spaces). The two-letter
  613. codes describing game types must be from the following list:
  614.  
  615.      Standard 2k game                      2K
  616.      Standard 4k game                      4K
  617.      Standard Atari bankswitched 8k game   8K
  618.      Standard Atari bankswitched 16k game  16
  619.      Atari Super-chip game                 SC
  620.      Parker Brothers 8k game               PB
  621.      M-Network 16k game                    MN
  622.      Starpath Supercharger game            SP
  623.      CBS 12k RAM-Plus game                 CB
  624.      TigerVision game                      TV
  625.      Pitfall II: Lost Caverns              P2
  626.      Activision Robot Tank or Decathlon    AC
  627.      Unknown                               ??
  628.      
  629. Likewise, the two-letter controller codes are as follows:
  630.      
  631.      Joystick                              JY
  632.      Paddle                                PD
  633.      Video Touch Pad                       VT
  634.      Indy 500 Driving Controllers          DR
  635.      Keyboard Controllers                  KB
  636.      Unknown                               %%
  637.      
  638.  
  639. The  automatically-generated profile file, PCAE.PRO, follows  the
  640. same  format  as  the known game profile file,  except  that  the
  641. emulator inserts a variable number of spaces between the filename
  642. and  the  two-letter game type code so that different codes  will
  643. appear in different columns (for readability). Although the  file
  644. can  be  modified, it will be automatically overwritten  whenever
  645. the  auto-generate option is selected from the popup menu; it  is
  646. meant  to  be readable by the user and supplemented by the  known
  647. file, PCAE.KNW, which overrides any settings in the automatically-
  648. generated profile file.
  649.  
  650. What is Bankswitching?
  651.  
  652. Before discussing bankswitching, it is first necessary to briefly
  653. explain  a little bit about the Atari 2600 architecture. The  VCS
  654. uses  a  processor  designated as the 6507, which  is  a  limited
  655. version  of the more popular 6502. The 6507 processor can address
  656. up  to 8k bytes of memory. In the 2600, some of this memory  area
  657. is  used for hardware support (e.g. video and audio), as well  as
  658. for  a  small amount of RAM in the console. Although much of  the
  659. address space is unused, there is generally 4k available for game
  660. programs.  It  was  not  long before  companies  like  Atari  and
  661. Activision realized that 4k of ROM was not enough to produce more
  662. complex games, so they had to devise a way to access more  memory
  663. even  though  the CPU in the system could not. They  accomplished
  664. this  with  bankswitching-placing higher-capacity  ROM  chips  in
  665. their cartridges but only letting the CPU "see" up to 4k of  them
  666. at a time. For example, a bankswitched 8k game might only let the
  667. CPU  see either the first 4k or the last 4k, but never both.  The
  668. switch  would  be  accomplished by special  hardware  that  would
  669. detect  any  CPU access to special "hot" memory addresses,  which
  670. the manufacturer would designate to the game programmers as areas
  671. for switching the bank.
  672.  
  673. Several  game  manufacturers used the bankswitching approach  for
  674. making  larger,  more  complex games,  but  they  tended  to  use
  675. different  game sizes and "hot" bankswitching addresses-they  had
  676. different bankswitching schemes. Some would switch the entire  4k
  677. area  at  a  time,  others switched smaller 1k areas,  and  still
  678. others  included extra RAM in their games. Since  each  of  their
  679. cartridges  contained  specialized  hardware  to  accomplish  the
  680. bankswitching,  there was no need for 2600 users to  worry  about
  681. which  scheme was being used by which manufacturer;  they  simply
  682. had  to  plug  the game in and turn the machine on. An  emulator,
  683. however,  does not have any specialized hardware to automatically
  684. detect a bankswitching type and accomplish it, so there has to be
  685. some  way to notify it whether bankswitching is involved and what
  686. kind it is.
  687.  
  688. Regarding  Pitfall II: Lost Caverns, the bankswitching  idea  was
  689. taken to an entirely new level. Not only does the game contain 8k
  690. of  game  code using somewhat standard bankswitching, as well  as
  691. some RAM, it also contains an additional 2k of data accessible by
  692. a  very  special  chip. Data can be accessed  in  standard,  bit-
  693. reversed, or reversed-nybble formats, and can be "bracketed" such
  694. that only data in a certain range is accessible. In addition,  it
  695. contains  a  three-channel square wave generator with  adjustable
  696. phase,  frequency, pulse width, and mixing attributes. Just  like
  697. standard  bankswitching, it is necessary  to  tell  the  emulator
  698. somehow  that this game is selected so that it knows  to  emulate
  699. these functions.
  700.  
  701. When the Game Is Running
  702.  
  703. Hopefully  at this point you have selected a game and are  seeing
  704. it  on the screen. It is recommended that the first games you try
  705. are  small 2k and 4k games with no bankswitching issues, just  to
  706. make  sure the emulator is running correctly instead of  possibly
  707. running a bankswitched game with the wrong game setting.
  708.  
  709. Once  the  game is visible, PCAE is actually emulating  the  game
  710. code  in  the  file. Since your PC doesn't have the six  switches
  711. that  are located on Atari 2600 consoles for playing a game,  the
  712. emulator maps certain function keys to those switches. Just  like
  713. on  the  actual console, you start by interacting with  the  game
  714. just  as  you  would with a VCS unit-but with the  function  keys
  715. instead of switches. The function key assignments are as follows:
  716.  
  717.      F1        Display a help/status popup window that shows  the
  718.                function  keys  available and lets  you  view  and
  719.                change the player difficulty settings, as well  as
  720.                enable or disable vertical autocentering
  721.      F2        Reset
  722.      F3        Toggle between NTSC and PAL screen palettes
  723.      F4        Select
  724.      F5        Color/Black-and-white toggle
  725.      F6        Player 1 difficulty toggle (A/B)
  726.      F7        Player 2 difficulty toggle (A/B)
  727.      Esc       Exit game (i.e. Power)
  728.      -         Shift screen downward
  729.      =         Shift screen upward
  730.      F10       Enable/disable vertical autocentering
  731.  
  732. In  addition,  Select and Reset are mapped to button  2  of  each
  733. joystick;  if  you are using a four-button joystick (e.g.  Gravis
  734. GamePad)  these  functions  are  accessible  directly  from   the
  735. joystick  as well as the keyboard. The one exception to  this  is
  736. for  12k  CBS  RAM-Plus games, since Omega  Race  requires  extra
  737. buttons  for the Booster-Grip joystick add-on that comes  bundled
  738. with  the  game. In this case, a four-button joystick is required
  739. to play the game.
  740.  
  741. Vertical  autocentering is a feature that attempts  to  optimally
  742. center  the  screen on your monitor. This is enabled by  default,
  743. and  works  well  for  nearly every game. However,  it  might  be
  744. desirable  to  disable this feature for certain  games;  in  this
  745. case, the F10 key can be used to toggle it.
  746.  
  747. Using Joysticks With PCAE
  748.  
  749. PCAE  will  work  with  either none,  one,  or  two  standard  PC
  750. joysticks. Either four-button or two-button joysticks will  work,
  751. but  it  is  recommended that one of the joysticks  support  four
  752. buttons to allow easy use of the Atari Select and Reset functions
  753. from  the  joystick instead of the keyboard. To  enable  joystick
  754. support, make sure they are first plugged into your game port. To
  755. connect  two  joysticks,  it might be  necessary  to  purchase  a
  756. joystick  "Y"  cable  to  connect both joysticks  to  a  standard
  757. joystick port. Some newer game port cards have two ports on them,
  758. such as the Gravis GameCard that sells for about $15.00 (US).
  759.  
  760. When  the  joystick(s) are connected, select "Calibrate  and  use
  761. joystick(s)"  from  the  popup menu. You will  be  prompted  with
  762. calibration  questions  for joystick  1.  At  this  point  it  is
  763. generally  a  good idea to center any X/Y trimmer adjustments  on
  764. the  joystick. After you have followed the directions,  the  same
  765. questions  will appear for joystick 2. If you have two  joysticks
  766. connected, you can follow them to calibrate it, but if  only  one
  767. is  connected, hit the <Esc> key to notify the emulator that only
  768. one joystick is connected. The emulator will turn off support for
  769. joystick  2  and  the keyboard will be activated for  player  2's
  770. functions.  In  the  event  that recalibration  is  desired,  the
  771. calibrate  option can be used to recalibrate all joysticks.  This
  772. is  also necessary when unplugging the second joystick to  switch
  773. control  for  player 2 back to the keyboard. If  unplugging  both
  774. joysticks,  select "Use keyboard" from the popup menu  to  switch
  775. back to keyboard-only mode.
  776.  
  777. Joystick ports on Intel PC's support four joystick buttons;  they
  778. can  be  used in various ways, but the most common configurations
  779. are (1) one joystick using all four buttons (e.g. Gravis GamePad)
  780. or  (2)  two  joysticks,  each using two  of  the  four  buttons.
  781. Whatever  the  configuration, PCAE  supports  using  two  of  the
  782. joystick  buttons  for player 1 and player 2 fire,  respectively,
  783. and the other two buttons for the Atari 2600 "select" and "reset"
  784. functions. In addition, PCAE allows these functions to be  mapped
  785. to  different joystick buttons. Selecting Remap Joystick  Buttons
  786. from  the  main  menu  will call up a popup menu  displaying  the
  787. current  joystick button assignments. A function can be  remapped
  788. to  a  different  joystick  button by selecting  the  appropriate
  789. function and then pressing the desired joystick button.
  790.  
  791. Using the Keyboard With PCAE
  792.  
  793. PCAE   has  the  capability  of  mapping  nearly  all  controller
  794. functions  to the keyboard (the only thing it cannot  emulate  on
  795. the  keyboard  is the paddle, which is emulated via  the  mouse).
  796. When  keyboard emulation becomes necessary, the keyboard mappings
  797. are as follows:
  798.  
  799. Joystick  and  Atari Indy 500 Controllers: (note  that  Indy  500
  800. controllers have no up or down motion)
  801.  
  802.      Joystick Player 1 fire   <Space> or keypad <Enter>
  803.      Joystick Player 1 up     Either up arrow key
  804.      Joystick Player 1 down   Either down arrow key
  805.      Joystick Player 1 left   Either left arrow key
  806.      Joystick Player 1 right  Either right arrow key
  807.      
  808.      Joystick Player 2 fire   normal <Enter>
  809.      Joystick Player 2 up     I
  810.      Joystick Player 2 down   K
  811.      Joystick Player 2 left   J
  812.      Joystick Player 2 right  L
  813.  
  814. Atari  Keyboard Controllers and Video Touch Pad: (note  that  the
  815. Video Touch Pad is the right keyboard controller only)
  816.  
  817.      Left Controller          Right Controller
  818.  
  819.         1  2  3                   4  5  6
  820.         Q  W  E                   R  T  Y
  821.         A  S  D                   F  G  H
  822.         Z  X  C                   V  B  N
  823.  
  824. CBS  Booster-Grip keys are emulated with the square bracket  keys
  825. "[" and "]" respectively.
  826.  
  827. Emulating Paddles With the Mouse and Joysticks
  828.  
  829. If you have a mouse connected and have a DOS mouse driver loaded,
  830. the  emulator will automatically detect the mouse and use it  for
  831. games  that use a paddle. If you are running PCAE from a  Windows
  832. DOS  prompt, mouse support might already be provided, so it might
  833. not  be  necessary to load a DOS mouse driver. If you have analog
  834. joystick(s) connected and calibrated, their horizontal  axes  can
  835. be used to emulate paddles two and three, respectively. Note that
  836. joysticks  used in this manner must be fully analog (i.e.  Gravis
  837. GamePads  and  the  like  won't work).  The  mouse  and  joystick
  838. assignments  can be changed with the "Change paddle  assignments"
  839. option from the main menu. There are four possible configurations
  840. (note how the mouse migrates from paddle 1 to paddle 4):
  841.  
  842.      Paddle 1  Mouse          Paddle 1  Joystick 1
  843.      Paddle 2  Joystick 1     Paddle 2  Mouse
  844.      Paddle 3  Joystick 2     Paddle 3  Joystick 2
  845.      Paddle 4  N/A            Paddle 4  N/A
  846.      
  847.      Paddle 1  Joystick 1     Paddle 1  Joystick 1
  848.      Paddle 2  Joystick 2     Paddle 2  Joystick 2
  849.      Paddle 3  Mouse          Paddle 3  N/A
  850.      Paddle 4  N/A            Paddle 4  Mouse
  851.  
  852. Using Real Atari Controllers With PCAE
  853.  
  854. PCAE  supports connecting real Atari 2600 controllers to your  PC
  855. if  you  have either built or acquired a special interface board.
  856. It connects to your PC's joystick port and a parallel port, which
  857. must  support  bidirectional transfer. Most motherboard  parallel
  858. ports  support  this, and are usually configurable for  standard,
  859. EPP (Enhanced Parallel Port), or ECP (Enhanced Capabilities Port)
  860. functionality.  The  joystick port should be a  fully  functional
  861. one, supporting two PC joysticks. If you have the board, you  can
  862. use  it to get the feel of playing an actual Atari 2600, as  well
  863. as play games requiring more than one paddle.
  864.  
  865. To  use  real controllers, first select "Set parallel port"  from
  866. the  popup  menu  to  choose the port number  that  matches  your
  867. bidirectional  parallel  port.  You  might  have  to   get   this
  868. information  from  your BIOS setup, jumper settings,  or  Windows
  869. configuration, depending on your hardware and software setup. The
  870. emulator  will display a list of all detected parallel ports  and
  871. prompt you to choose one. Once this is done, select "Toggle using
  872. real  controllers" from the popup menu. PC joystick and  keyboard
  873. support  will be turned off, and the board will be polled instead
  874. for  controller information. The final step is to calibrate  your
  875. paddle controllers. Connect a set of Atari paddle controllers  to
  876. the  player 1 port of the controller board, and select "Calibrate
  877. paddles"  from the popup menu. You will be prompted to  turn  the
  878. paddles  fully  counterclockwise and hit a key.  This  tells  the
  879. emulator the full extent of their travel as reported by  your  PC
  880. and  will allow both sets of paddles to be connected and properly
  881. emulated by the program. It is necessary to calibrate the paddles
  882. only  once,  since the information is saved in the  configuration
  883. file.
  884.  
  885. Please  note that the current board design that comes  with  this
  886. documentation was tested with Atari joystick controllers,  paddle
  887. controllers,  keyboard controllers, Indy 500 driving controllers,
  888. and  the  CBS  Booster-Grip.  In all cases  except  the  keyboard
  889. controllers,   everything   worked  fine.   With   the   keyboard
  890. controllers,  however,  only  the  first  two  columns  of   each
  891. controller  worked. Perhaps someone else might  design  a  better
  892. interface board that will make them work fully.
  893.  
  894. Slowing Down the Emulator For Faster PC's
  895.  
  896. At  the  time  PCAE  was written, many people  were  still  using
  897. computers  with i486 and slower Pentium processors. The  assembly
  898. implementation  was  absolutely necessary  to  achieve  a  decent
  899. emulation  speed.  Since  then, faster Pentium  and  Pentium  Pro
  900. processors have become affordable, which presents the problem  of
  901. games  that  run far faster on the emulator than on the  original
  902. Atari  2600. To address this problem, the popup menu  contains  a
  903. feature  that  can  be used to limit the emulator  to  display  a
  904. certain  number of frames per second. For example, standard  NTSC
  905. Atari  2600's  display at 60 fps, so selecting  "Set  frames  per
  906. second"  from the popup menu and entering "60" should  limit  the
  907. emulator  to  the  standard NTSC Atari speed. In  addition,  this
  908. feature can be used to make certain games either easier or harder
  909. by slowing them down or allowing them to be played faster.
  910.  
  911. For users running the emulator from within an OS/2 DOS prompt, it
  912. may  be  necessary to select an option allowing DOS  programs  to
  913. access  the hardware timer for PCAE to run properly. The  frames-
  914. per-second slowdown feature uses the hardware timer to  determine
  915. how  much  time  has  elapsed since the  last  emulated  vertical
  916. refresh. Based on the number of frames per second it is  told  to
  917. display, it enters a waiting loop until a certain amount of  time
  918. has elapsed.
  919.  
  920. In  certain  rare  circumstances, it might be  necessary  to  use
  921. different fps values either with certain system configurations or
  922. after  an  upgrade.  This is very unusual, but  there  have  been
  923. reports  of  erroneous  timer information reaching  the  emulator
  924. somehow. In cases where 60 frames per second results in very slow
  925. operation, try half-multiples such as 90, 120, etc.
  926.  
  927. Configuring the Emulator's Sound Output
  928.  
  929. There  are  three  features that can be used to configure  PCAE's
  930. sound  output. The first is merely a sound support toggle,  which
  931. turns all sound on or off via the "Toggle sound" option from  the
  932. popup menu. The next two features are accessed via the "Set sound
  933. options"  option; this allows the sound buffer size and  playback
  934. rate  to be adjusted. The emulator simulates the sound output  of
  935. the  2600  by  calculating sound samples at  maximum  volume  and
  936. storing  them  in  XMS memory. When a sound is requested,  it  is
  937. loaded  into a buffer, adjusted for volume, mixed with the  sound
  938. output  of  the  second  channel (Atari 2600's  have  two-channel
  939. sound),  and  output. This takes a certain amount  of  time,  and
  940. setting  smaller buffer sizes will decrease the time it takes  to
  941. perform  this  action-resulting  in  faster  emulation.  However,
  942. smaller buffer sizes also degrade the sound quality, so there may
  943. a tradeoff in adjusting this value for slower PC's.
  944.  
  945. The  second  parameter that is adjustable along with  the  buffer
  946. size  is the sound card's playback rate. By default, the emulator
  947. sets  the  sound card to output the sound at a rate of 31400  Hz,
  948. which  is  the same rate that drives the original Atari 2600  and
  949. results  in very good sound quality. This seems to work for  most
  950. sound  cards, but there are a few that have had problems  getting
  951. sound to run. After testing this on a Pro Audio Spectrum 16 sound
  952. card,  it  was found that a slower playback rate would work  much
  953. better  on  this  card. You can select from four playback  rates:
  954. 31400  Hz,  22050 Hz, 15700 Hz, and 11025 Hz. It  is  recommended
  955. that  you  use  the highest rate that your sound  card  supports,
  956. since  lower  rates  decrease sound  resolution  and  thus  sound
  957. quality.
  958.  
  959. PCAE160: The Other VCS
  960.  
  961. Included  in  the  PCAE  distribution  is  a  second  executable,
  962. PCAE160.EXE.  This  program  functions  nearly  exactly  as   the
  963. standard emulator, but uses a non-standard 160x200x256 video mode
  964. instead of the usual 320x200x256 (mode 13h). This mode allows the
  965. emulator's display code to perform less work to display playfield
  966. graphics,  resulting  in  a ten to fifteen  percent  increase  in
  967. overall  emulation speed. However, since this is  a  non-standard
  968. video   mode,   it  is  not  compatible  with  all   VGA   cards.
  969. Specifically, some video cards may display none or only a portion
  970. of   the  screen  in  this  mode,  a  result  of  differences  in
  971. interpreting  the  End  Horizontal  Blanking  value.  Very   fast
  972. machines (Pentium-100 and faster) should not need this program at
  973. all;  it  is  intended for slower machines that need every  boost
  974. they  can  get. If, after using PCAE.EXE you find that  this  one
  975. works  as  well,  then  you  can  feel  free  to  use  this   one
  976. exclusively,  but it is certainly not expected to  be  compatible
  977. with  many (or even a majority) of VGA cards. I have successfully
  978. tested  it with three ATI video cards, a local-bus Mach  32-based
  979. card with 2Mb of VRAM, a Mach 64-based WinTurbo 2MBU/4MB upgraded
  980. to 4Mb of VRAM, and the 3D Pro Turbo PC2TV with 8Mb of SGRAM.
  981.  
  982. =================================================================
  983. 4       Development Tools
  984.  
  985. In  addition  to  the  emulation engine, PCAE  includes  features
  986. designed  to assist developers of Atari 2600 programs  and  other
  987. Atari 2600 emulators. It contains an integrated debugger that can
  988. be  run in conjunction with any 2600 program by either using  the
  989. "DEBUG"  command  line parameter or using the  "Toggle  debugger"
  990. option  from the popup menu. It has a somewhat similar  look  and
  991. feel  to  Borland's Turbo Debugger, but with only those  features
  992. that  are  basic to program debugging in general and specific  to
  993. the Atari 2600:
  994.  
  995. o    Display of program code in a code window which can be
  996.      navigated using the cursor keys
  997. o    Display of all 6507 register contents as well as flag bits
  998. o    Display of the contents of Atari RAM addresses 80h to FFh
  999. o    Displays the contents of the GRP0 and GRP1 player graphics
  1000.      registers
  1001. o    Displays the current bank number for some bankswitching
  1002.      schemes
  1003. o    Displays the scan line and horizontal position of the Atari
  1004.      CRT beam
  1005. o    Displays the screen address that corresponds to the beam
  1006.      position
  1007. o    Ability to execute unhindered, trace into, trace over,  and
  1008.      execute until specific instructions or specific scan lines
  1009. o    Online command reference and TIA register reference
  1010. o    Ability to switch the debugger display to 320x400x256 video
  1011.      mode (should be compatible with all VGA cards) to display
  1012.      additional information
  1013. o    Can display the current contents of the emulated video
  1014.      screen
  1015. o    Ability to enter multiple bytes of data into the 6507's
  1016.      addressable range
  1017. o    Ability to change a 6507 register's contents
  1018. o    Ability to save the ROM range 1000h-1FFFh to disk
  1019.  
  1020. All debugger commands are invoked with certain keystrokes:
  1021.  
  1022.      <Cursor keys>  Navigate the code window
  1023.      D           Display toggle- toggle between standard
  1024.                  320x200x256 mode and 320x400x256 mode
  1025.      E           Enter one or more bytes of data into the 6507's
  1026.                  address range
  1027.      G           Go- execute the code unhindered until <Esc> is
  1028.                  pressed
  1029.      H           Run to here- execute until the instruction at
  1030.                  the top of the code window
  1031.      L           Run until a specific scan line
  1032.      R           Change a 6507 register's contents
  1033.      S           Step over-execute until next instruction
  1034.      T           Trace-execute current instruction only
  1035.      Z           Save 4k data area 1000h to 1FFFh to disk
  1036.      <Ins>       Move the highlight to the instruction pointed to
  1037.                  by the Program Counter
  1038.      <Space>     Display the contents of the emulated game screen
  1039.      <Esc>       Exit the debugger and return to the main menu
  1040.      <F1>        Display the help reference screens
  1041.  
  1042. When in 320x400x256 mode, the debugger also displays the contents
  1043. of  the  TIA output registers located at memory locations 00h  to
  1044. 2Ch,  as  well as the contents of the TIA input registers located
  1045. at  memory  locations  00h  to 0Dh. In addition,  the  horizontal
  1046. positions of the player 1 graphics, player 2 graphics, missile  1
  1047. graphics, missile 2 graphics, and ball graphics are displayed. If
  1048. any  of  the graphics objects are enabled (if the GRPx  registers
  1049. contain  nonzero values or if bit 1 the ENAxx registers is  one),
  1050. then  the horizontal position for those objects are displayed  in
  1051. purple instead of black.
  1052.  
  1053. Debugger Layout
  1054.  
  1055. The  largest  window,  in the upper left corner  of  the  screen,
  1056. displays  the  assembly code in the 2600 game program.  A  yellow
  1057. highlight  bar  will  be positioned on the  next  instruction  to
  1058. execute  and  the code window can be navigated using  the  cursor
  1059. keys.  To  the right of the code window is an area that  displays
  1060. the  contents of the 6507 P (flag) register, and right below that
  1061. is  an  area that displays the contents of all the 6507 registers
  1062. in  hexadecimal  format. Farther down, the  beam  scan  line  and
  1063. horizontal  position,  its  corresponding  screen  address,  bank
  1064. number, and GRP0 and GRP1 register contents are displayed.
  1065.  
  1066. At  the  bottom  of  the debugger screen is a  data  window  that
  1067. displays  the  contents of the 2600 RAM area, located  at  memory
  1068. locations 80h to FFh. When in 320x400x256 mode, between the  code
  1069. window  and  the main data window are three smaller data  windows
  1070. that  display the TIA write registers and read registers, as well
  1071. as  the horizontal positions of all five graphics objects (player
  1072. 1, player 2, missile 1, missile 2, and ball).
  1073.  
  1074. Entering one or more bytes of data
  1075.  
  1076. Using  the  "E"  key from the debugger brings up a pop-up  window
  1077. that  allows you to enter a target address and one or more  bytes
  1078. of data. The format of the entry should be a hexadecimal address,
  1079. and  equal sign, and one or more hexadecimal bytes, separated  by
  1080. spaces.  If a data entry is invalid, that address in the list  is
  1081. skipped.  Note  that all addresses are bitwise-ANDed  with  1FFFh
  1082. while all data bytes are ANDed with FFh. Also, the debugger  does
  1083. not have the hooks to the code that affects the TIA's output, and
  1084. therefore this method cannot be used to change TIA registers  (it
  1085. will  only  allow  addresses in the range (80h  to  1FFFh  to  be
  1086. changed).  Pressing  <Esc> at any time  aborts  the  data  entry.
  1087. Finally,  be aware that for bankswitched games, all changes  made
  1088. are  temporary-when the bank is switched, all  changes  made  are
  1089. lost.
  1090.  
  1091.      Examples
  1092.  
  1093.      1004=00 4 34 AE D3 2F         Enters these six bytes into
  1094.                                    1004h to 1009h
  1095.      143F=56 - 4E 33               Enters 56h, 4Eh, and 33h into
  1096.                                    143Fh, 1441h, and 1442h
  1097.  
  1098. Stopping execution at a certain scan line
  1099.  
  1100. Choosing  the "L" key brings up a pop-up window that asks  for  a
  1101. scan  line  value. Entering one starts execution of the  program,
  1102. which  will halt and return to the debugger when that  scan  line
  1103. value  is  reached. If a number is entered that is never  reached
  1104. (e.g.  300), execution will continue until <Esc> is pressed.  You
  1105. can abort entering a number by hitting <Esc> at any time.
  1106.  
  1107. Changing a 6507 register's contents
  1108.  
  1109. Hitting  the "L" key opens a pop-up window that asks for  a  6507
  1110. register  and  value  to be entered. The  format  should  be  the
  1111. register  name,  an  equal sign, and a hexadecimal  value  to  be
  1112. entered. Hitting <Esc> aborts the process.
  1113.  
  1114.      Examples
  1115.  
  1116.      PC=13F3h                Changes the program counter to 13F3h
  1117.      A=3                     Changes the accumulator to 03h
  1118.      P=E2                    Changes the flags register to E2h
  1119.      X=26                    Changes the X register to 26h
  1120.      S=9A                    Changes the stack register to 9Ah
  1121.      Y=71                    Changes the Y register to 71h
  1122.      
  1123. Note  that data entries are ANDed with FFh to keep the  value  in
  1124. the legal byte range.
  1125.  
  1126. Saving to Disk
  1127.  
  1128. Since the "E" key allows you to interactively change a game  file
  1129. as  it runs, the "Z" key allows you to permanently save the final
  1130. ROM dump to disk. Hitting "Z" brings up a pop-up window that lets
  1131. you  enter a path and filename at which to save the file. Invalid
  1132. filenames  will be ignored, and hitting <Esc> lets you abort  the
  1133. process.
  1134.  
  1135. The Disassembler
  1136.  
  1137. PCAE  also  includes a disassembler for building  6507  assembler
  1138. listings of game files that are 4k in size or smaller, as well as
  1139. many  8k, 16k, Super-Chip, and CBS RAM-Plus games. It is  invoked
  1140. with  the "DISASM" command-line option, generating a source  file
  1141. called  LISTING.ASM.  It automatically detects  the  game  code's
  1142. starting  point  and attempts to differentiate between  code  and
  1143. data  areas by recursively following all code paths.  It  is  not
  1144. capable of disassembling games that have other bankswitch  types,
  1145. nor  can  it  follow  code paths generated  by  jump  tables.  To
  1146. disassemble  bank-switched games, it  is  important  to  use  the
  1147. proper  bankswitching command-line options to tell  the  emulator
  1148. that they are in effect.
  1149.  
  1150. =================================================================
  1151. 5       The Real Controller Board
  1152.  
  1153. PCAE  supports connecting real Atari 2600 controllers to your  PC
  1154. via  a  special  board that connects to a bidirectional  parallel
  1155. port  and  a  fully functional joystick port. The board  I  built
  1156. requires  the following parts, though many variations on  it  can
  1157. exist:
  1158.  
  1159. 1 25-pin ribbon cable
  1160. 1 34-pin IDC connector (connected to the 25-pin ribbon cable)
  1161. 1 DB25 connector, connected to the 25-pin ribbon cable (plugs
  1162.   into the parallel port)
  1163. 1 DB15 connector (plugs into the joystick port) I cannibalized an
  1164.   old joystick and cut off the connector.
  1165. 1 15-pin ribbon cable and IDC connector to connect the DB15
  1166.   connector to
  1167. 2 DB9 connectors (Atari controllers plug into them). I used
  1168.   connectors that come with serial I/O cards that have DB9
  1169.   connectors at one end and IDC connectors at the other end.
  1170. 4 IDC headers (series of pins that the IDC connectors plug into)
  1171.   (one 26, one 16, and two 10-pin headers)
  1172. 1 solder-type board
  1173. 8 1k resistors (I used ½-watt resistors)
  1174. 8 4.7k resistors (I used ¼-watt resistors)
  1175. some wire
  1176.  
  1177. Most  of  these parts can be bought at Radio Shack. The schematic
  1178. is as follows: (see inlcuded file control.gif or control.wmf)
  1179.  
  1180. =================================================================
  1181. 6       Troubleshooting
  1182.  
  1183. The computer hangs (or the emulator crashes) when the emulator is
  1184. run
  1185.  
  1186. First,  make  sure that there is enough low DOS  and  XMS  memory
  1187. available for the program. To get more low DOS memory, you  might
  1188. have  to change your system configuration, such as removing TSR's
  1189. from either your AUTOEXEC.BAT or CONFIG.SYS files, or perhaps  by
  1190. loading them into upper memory blocks (UMB's). XMS memory must be
  1191. provided  by  an XMS memory manager, such as HIMEM.SYS  (provided
  1192. with  MS-DOS  and Microsoft Windows). There are also  third-party
  1193. memory  managers which might help, such as 386MAX and  QEMM.  You
  1194. can  usually  find  out how much memory is avaiilable  by  typing
  1195. "MEM"  from  the  DOS prompt. The amount of XMS  memory  required
  1196. depends  on the sound buffer size you have chosen from  the  main
  1197. menu;  for a 4k buffer size, 2Mb of XMS is required (a 2k  buffer
  1198. size requires 1Mb of XMS, etc.)
  1199.  
  1200. If  you have met the memory requirements, the next thing to check
  1201. is  if your BLASTER environment string is set properly if you are
  1202. using  sound support. An incorrectly set environment string could
  1203. cause  lockups if sound is enabled in the emulator. You can  test
  1204. this  by  disabling sound support with the "Toggle sound"  option
  1205. and  then  attempting  to  play a  game.  If  the  emulator  runs
  1206. properly,  this  could  be an indication of  an  incorrectly  set
  1207. BLASTER  environment string. If this is the case, please see  the
  1208. earlier  section on setting the emulator up for help  or  consult
  1209. your sound card's documentation.
  1210.  
  1211. If both the memory and sound setups are correct but you are still
  1212. experiencing lockups, check to see if you have a DOS mouse driver
  1213. loaded if you are not running the emulator from a Windows or OS/2
  1214. MS-DOS  prompt (i.e. you are in true MS-DOS mode). Not  having  a
  1215. DOS  mouse driver loaded really shouldn't cause a lockup, but  it
  1216. is  recommended  (and necessary to emulate paddle games).  Common
  1217. mouse drivers are usually called MOUSE.SYS or MOUSE.EXE.
  1218.  
  1219. If  you are running the emulator from an OS/2 DOS prompt, be sure
  1220. to  enable access to the hardware timer in the DOS prompt  setup.
  1221. There has been a report from an OS/2 user who found out that  the
  1222. emulator would not run without this enabled.
  1223.  
  1224. The emulator runs VERY slowly
  1225.  
  1226. The  first  thing  to check is your computer's speed.  Benchmarks
  1227. have  shown that, using PCAE.EXE, a Pentium-90 can run most games
  1228. at  about 110% of a normal 2600's speed. A Pentium-60 will run at
  1229. two-thirds of a P90, and a 486-66 will run at about 55% to 60% of
  1230. a  P60.  There have been reports that a 486-120 can run games  at
  1231. about  100% of an Atari 2600. If your computer is slower  than  a
  1232. 486-66, expect slow operation. You can find out how fast your  PC
  1233. is  emulating the 2600 by running a game with a timer (such as  a
  1234. sports  game) and timing how long it takes to count to a  certain
  1235. point. Remember, though, to set the frames-per-second value to  0
  1236. to  allow  the  emulator  to  run  as  fast  as  possible  before
  1237. performing benchmarks.
  1238.  
  1239. If  tests show that the games are not being emulated as  fast  as
  1240. they   should,  the  first  thing  to  check  is  your   joystick
  1241. calibration  setup. If you do not have joysticks  connected,  you
  1242. should  make  sure  to  disable joystick support  with  the  "Use
  1243. keyboard"  option. Otherwise, the emulator will  constantly  poll
  1244. the  joysticks,  which  can take a very long  time  if  none  are
  1245. connected.  Similarly,  if only one joystick  is  connected,  you
  1246. might  want to recalibrate the joystick, making sure to  hit  the
  1247. Esc  key  when asked to calibrate the second joystick. This  will
  1248. tell the emulator that only one joystick is connected and prevent
  1249. it  from constantly polling joystick two. If the above procedures
  1250. don't help, try changing the frames-per-second value. There  have
  1251. been  occurrences  where certain video cards  incorrectly  report
  1252. vertical refresh information to the emulator, causing it to  slow
  1253. itself down more than it should. Trying higher values for frames-
  1254. per-second might help.
  1255.  
  1256. Finally, if all else fails, check if your computer has a  "turbo"
  1257. feature,  usually a button on the case. The effect of  the  turbo
  1258. being  off  should be very noticeable, since ALL software  should
  1259. run  slowly. Make sure the turbo is ON, usually indicated  by  an
  1260. LED nearby.
  1261.  
  1262. The  emulator runs more slowly when I use joysticks than  when  I
  1263. use the keyboard
  1264.  
  1265. It  is  normal  to experience a 10 percent or so  degradation  of
  1266. emulation speed when using joysticks with the emulator.  This  is
  1267. due  to  the method required to read analog joysticks.  They  can
  1268. only  be read by initializing the joystick port and waiting until
  1269. a  certain bit flips or until a time limit has been reached. This
  1270. occasional waiting loop causes the loss in emulation speed.
  1271.  
  1272. The emulator runs, but there is no sound
  1273.  
  1274. Sometimes simple solutions are the best; make sure that sound  is
  1275. enabled  with the "Toggle sound" option, and check  to  see  that
  1276. your  speakers are connected and on if they have a power  switch.
  1277. If  your  speakers support optional external power  supplies  for
  1278. additional amplification, you might have to set the power  switch
  1279. to  "Off"  if you are not using any additional power  supply  for
  1280. them.  Try  testing sound with another program to make sure  your
  1281. sound card and speakers are set up properly.
  1282.  
  1283. If  sound  is enabled and your speakers are set up properly,  the
  1284. problem  is  most  likely an incorrectly set BLASTER  environment
  1285. string.  See the earlier section on setting the emulator  up  for
  1286. help  with  this, or consult your sound card's documentation.  If
  1287. there still isn't sound, check to make sure your sound card's IRQ
  1288. and DMA are supported by the emulator.
  1289.  
  1290. If  your  sound  card has mixer software or you  are  running  in
  1291. Windows  95,  check  your mixer settings to make  sure  they  are
  1292. correct. For DOS users, you should have mixer software that  came
  1293. with   your   card,  or  they  might  be  available   from   your
  1294. manufacturer.  For  example, my Sound Blaster  16  SCSI-2  has  a
  1295. program  called  SB16MIX.EXE, a DOS TSR  that  lets  me  set  the
  1296. individual  mixer  settings. Windows users  should  have  similar
  1297. software,  and  Windows 95 users can try double-clicking  on  the
  1298. little speaker icon in the system tray at the bottom right of the
  1299. screen. You should make sure that the digital and FM outputs  are
  1300. the  same  value (they are usually called "wave" and "midi")  and
  1301. that the master volume is not zero or a small value.
  1302.  
  1303. Incompatible cards are extremely rare these days, but  make  sure
  1304. your  sound  card  is  100% Sound Blaster-compatible,  preferably
  1305. Sound  Blaster Pro compatible (a simple AdLib FM card or Creative
  1306. Labs  Game  Blaster  will  not do). In my  opinion  there  is  no
  1307. substitute for a true-blue Creative Labs part, but they  tend  to
  1308. command a premium.
  1309.  
  1310. I  have sometimes had problems after running other software  that
  1311. would  cause  the  sound card to become inaccessible  afterwards.
  1312. Turning  off your computer and turning it back on will reset  the
  1313. sound card and might help matters.
  1314.  
  1315. I  get no music in Pitfall II, the music is very quiet, or is too
  1316. loud relative to the game sounds
  1317.  
  1318. The  first thing to check is the mixer sound card settings.  This
  1319. is  described  in the prior troubleshooting section.  You  should
  1320. make  sure that the digital and FM settings are equal,  and  that
  1321. the  master volume is neither small nor zero. Also, you  can  try
  1322. turning your computer off and on to reinitialize the sound card.
  1323.  
  1324. If  you still don't get sound, perhaps your sound card isn't 100%
  1325. Sound Blaster compatible. Check the documentation that came  with
  1326. your  sound card to see if it supports FM synthesis. If it  does,
  1327. you  can  try other software to make sure that the FM is working.
  1328. For  example, Creative Labs cards usually come with  a  DOS  test
  1329. program, e.g. TESTSBP.EXE, TESTSB16.EXE, etc.
  1330.  
  1331. The emulator runs too fast; games are unplayable
  1332.  
  1333. From  the popup menu, select the "Set frames per second"  option.
  1334. You will be asked to enter a number of frames per second at which
  1335. the  emulator  will run. This causes the emulator  to  limit  its
  1336. speed  so  as  not  to exceed the frame rate  that  you  specify.
  1337. Entering zero will cause the emulator to run as fast as possible.
  1338. For  standard NTSC Atari 2600's you should enter 60, which should
  1339. limit the emulator to running at 60 frames per second.
  1340.  
  1341. If  you  had  already done this and the emulator still  runs  too
  1342. fast,  your video card might not be correctly reporting  vertical
  1343. refresh rates to the emulator. Try smaller values, like 45 or 30.
  1344.  
  1345. The  cursor is uncontrollable from the main menu; it keeps moving
  1346. by itself
  1347.  
  1348. This probably indicates that either (1) you do not have joysticks
  1349. connected  but  joystick  support is enabled,  or  (2)  you  have
  1350. joystick(s),  but they either need to be recalibrated  or  aren't
  1351. connected.  If  there are no joysticks, disable joystick  support
  1352. with  the  "Use keyboard" option. The emulator will stop  polling
  1353. the  joysticks  for  cursor  movement,  and  will  only  use  the
  1354. keyboard. If you have joysticks, make sure they're connected  and
  1355. recalibrate them with the "Calibrate and use joystick(s)"  option
  1356. (see the earlier section for the calibration instructons).
  1357.  
  1358. The menu doesn't show any games to run
  1359.  
  1360. Make  sure you are running PCAE from the right directory. If  the
  1361. game  files  are in a different directory than the emulator,  you
  1362. have  to  specify the alternate directory from the  command  line
  1363. (e.g.  PCAE  G:\GAMES).  Also, make  sure  that  all  games  have
  1364. extensions of either .BIN or .PAL, the only extensions  the  menu
  1365. displays.
  1366.  
  1367. When I try to run the program I get a "Runtime error" message.
  1368.  
  1369. Make sure that the emulator is in the current directory, not in a
  1370. different directory than the one you are in. For example,  typing
  1371. "C:\PCAE\PCAE" from a directory other than C:\PCAE will not work,
  1372. since the emulator looks in the current directory for its support
  1373. files. Also, make sure none of the support files included in  the
  1374. PCAE  distribution are missing. If you are running  the  emulator
  1375. from  a  Windows  shortcut, make sure to specify PCAE's  starting
  1376. directory in the shortcut setup. If you are trying to specify  an
  1377. alternate directory for games (e.g. PCAE G:\GAMES), make sure the
  1378. alternate directory actually exists (i.e. make sure that G:\GAMES
  1379. exists and is a directory, not just a file).
  1380.  
  1381. The emulator works on one computer, but one of the above problems
  1382. arises when I copy it to another machine
  1383.  
  1384. Different   machines   have  different  hardware   and   software
  1385. configurations.  Make  sure there is adequate  memory,  that  the
  1386. sound  setup is correct, and either disable keyboard  support  in
  1387. the   emulator   or   recalibrate  the   joystick.   Follow   the
  1388. troubleshooting  help for the given problem to attempt  to  solve
  1389. it.
  1390.  
  1391. When  I  try to run a certain game, I either get a black  screen,
  1392. garbage on the screen, or it exits immediately
  1393.  
  1394. There  are  three possibilities: (1) the game isn't supported  by
  1395. the  emulator; (2) the game is a different type than the one  you
  1396. have  specified, or (3) the game is a bad ROM dump. If  the  game
  1397. isn't  supported, there really is nothing you can do;  perhaps  a
  1398. future version might support it. For bankswitched games, you  can
  1399. try  other  bankswitching types for that game size; for  example,
  1400. try  Parker Brothers 8k instead of standard Atari 8k. If you have
  1401. generated  the  game profile and are trying to run  the  game  by
  1402. pressing the Enter key, perhaps the game is a different type  and
  1403. needs  to be added to the known game profile file. Also,  if  you
  1404. have added a game to the known profile file or changed its entry,
  1405. make  sure  you have regenerated the standard profile afterwards,
  1406. since changes to PCAE.KNW will not take effect until PCAE.PRO has
  1407. been regenerated. If you can establish the proper game type,  you
  1408. can  edit  the  known game file, add the game to  the  list,  and
  1409. regenerate  the  profile  file from the popup  menu.  If  nothing
  1410. works, perhaps it is a bad copy of the game.
  1411.  
  1412. When  PCAE160 is run, all or part of the screen is blank  when  a
  1413. game is run
  1414.  
  1415. PCAE160  reprograms  the VGA registers to attempt  to  achieve  a
  1416. 160x200x256  screen mode that lets the emulator do less  work  to
  1417. display  playfield graphics. This results in  a  ten  to  fifteen
  1418. percent speed increase, but, being a non-standard video mode,  is
  1419. not  compatible with all VGA cards. If the above symptoms  occur,
  1420. PCAE160  might not be compatible with your VGA card. It has  been
  1421. tested  with several cards manufactured by ATI Technologies  with
  1422. good results, but this is no guarantee of compatibility with  all
  1423. brands. At any rate, for machines of equal or faster speed than a
  1424. Pentium-100, this program should be unnecessary.
  1425.  
  1426. I'm having trouble calibrating my joystick(s)
  1427.  
  1428. First, make sure they are connected properly, and test them  with
  1429. some  other  piece of software to ensure that the  joysticks  and
  1430. joystick port are working properly. Then, you should examine your
  1431. joysticks  for what are usually known as X/Y trimmer adjustments.
  1432. These usually take the form of knobs or sliders, and are used for
  1433. fine adjustment. Before calibrating the joystick, you should make
  1434. sure the trimmer adjustments are centered (not at either extreme)
  1435. to  allow  the  fullest range of values to  be  reported  by  the
  1436. joystick.
  1437.  
  1438. If centering the trimmers and recalibrating doesn't help, and you
  1439. have  a speed-adjustable joystick port, you might want to examine
  1440. the speed setting of the port. If you have a driver that sets the
  1441. speed  when  you boot up, sometimes simply rebooting or  powering
  1442. down  and back up helps, since this will reset the joystick  port
  1443. to  your speed setting. It might be necessary to change the speed
  1444. setting as a last resort, but this usually isn't necessary.
  1445.  
  1446. One  of  the joystick buttons doesn't work, or hitting a joystick
  1447. button causes more than one thing to happen
  1448.  
  1449. You  might  have a problem with your joystick. Make  sure  it  is
  1450. fully  plugged  in, and test it with some other software.  If  it
  1451. works  fine  with  other  software,  check  the  joystick  button
  1452. mappings by selecting "Remap Joystick Buttons" from the main menu
  1453. to  make  sure that you don't have more than one thing mapped  to
  1454. the same joystick button. If the joystick has problems with other
  1455. software  as  well, try remapping the buttons to  compensate.  In
  1456. this  case, you might consider buying either a new joystick or  a
  1457. new game port. You might be able to tell where the problem is  by
  1458. trying a different joystick to see if the problem persists.
  1459.  
  1460. I'm  trying  to  use  real controllers, but it  doesn't  work  or
  1461. doesn't work fully
  1462.  
  1463. There   could  be  several  problems.  First,  make   sure   real
  1464. controllers   are  enabled  by  selecting  "Toggle   using   real
  1465. controllers"  from the popup menu. Second, you should  make  sure
  1466. you  have  selected the right parallel port for the emulator;  it
  1467. must  be one that supports bidirectional transfer. You can try  a
  1468. different  port by selecting "Set parallel port" from  the  popup
  1469. menu.  Also, make sure the board is properly plugged in and  that
  1470. Atari  controllers are properly plugged into the  board.  If  you
  1471. built the board yourself, make sure it is done properly.
  1472.  
  1473. If  none  of  the  above steps works, it is  possible  that  your
  1474. parallel port is not set up properly. Make sure it is enabled  by
  1475. either  checking your jumpers or entering your BIOS setup.  Also,
  1476. if your port supports standard, EPP, or ECP modes, try setting it
  1477. to  a  different mode. You can also try running the emulator  and
  1478. board  on  a  different  PC to see if the parallel  port  is  the
  1479. problem.  Also, make sure the joystick port is a fully functional
  1480. one  that  supports two joysticks. You can test this by  plugging
  1481. two  joysticks into it using a joystick "Y" cable and making sure
  1482. that  both  joysticks work. You also should consider checking  to
  1483. see  if  your  parallel port's port number or IRQ conflicts  with
  1484. other  hardware, since some computers will have their sound cards
  1485. and parallel ports share IRQ settings.
  1486.  
  1487. If  you're having trouble with keyboard controllers or the  Video
  1488. Touch Pad, please note that the board design that comes with this
  1489. documentation does not fully support keyboard controllers. In the
  1490. tests  that  were  run,  only  the  first  two  columns  of  each
  1491. controller  worked.  Perhaps someone more knowledgeable  will  be
  1492. able  to  design a board that will make them work fully with  the
  1493. emulator.
  1494.  
  1495. When  I  run  PCAE, I get an error like "EMM386: Unsupported  DMA
  1496. mode. Press Enter to reboot"
  1497.  
  1498. There  seems  to  sometimes be a problem when running  PCAE  with
  1499. EMM386,  if your sound card is compatible with Sound Blaster  DSP
  1500. version  2.00 or higher (the vast majority of sound  cards).  The
  1501. problem  is  that  EMM386 doesn't always like the auto-initialize
  1502. DMA  mode  that the emulator uses to achieve near-perfect  sound.
  1503. The  best suggestion is to either run the emulator from within  a
  1504. Windows  3.x or Windows 95 prompt, or remark out the EMM386  line
  1505. from your CONFIG.SYS file.
  1506.  
  1507. =================================================================
  1508. 7       Acknowledgements
  1509.  
  1510. Over the past few years while I have been developing PCAE, I have
  1511. been  lucky  enough to receive a lot of help from  some  gracious
  1512. people.  This should in no way be considered an exhaustive  list;
  1513. I've gotten so much feedback over the past two years from so many
  1514. people  that  I could never list everyone-my email folder  simply
  1515. isn't  that  large, so if you aren't included here, please  don't
  1516. take  any offense. I am grateful for all the assistance that  has
  1517. come my way.
  1518.  
  1519. Those who helped (not necessarily in any real order)
  1520.  
  1521. Matt Conte: First and foremost, for giving PCAE a home! Also  for
  1522. spreading the word, doing lots of beta testing, getting  me  info
  1523. and  tools  I needed, fielding a lot of the email, and  generally
  1524. being really helpful.
  1525.  
  1526. Kevin  Horton: Helped me with a lot of technical details  of  the
  1527. 2600  especially bankswitching issues and Pitfall II deciphering.
  1528. Also  made sure I knew about every kind of bankswiching  game  he
  1529. could get his hands on.
  1530.  
  1531. Norbert  Juffa:  Wrote  the millisecond timer  used  in  the  fps
  1532. limiting code.
  1533.  
  1534. Dan Melton: Wrote the keyboard interrupt service routine.
  1535.  
  1536. Ron Fries: Wrote the TIA sound routines and sent them to me.
  1537.  
  1538. Dan Boris: Introduced me to Ron Fries' sound routines.
  1539.  
  1540. Dave  W.  (Dave's Video Game Classics): Did lots  of  testing  of
  1541. PCAE,  and supplied a whole bunch of good suggestions to make  it
  1542. better.
  1543.  
  1544. Jim  Leonard: Provided lots more web space for PCAE, as  well  as
  1545. did  some  very  important  testing of the  final  version.  Also
  1546. converted the documentation and schematics to HTML.
  1547.  
  1548. Bradford  W.  Mott  and Keith Wilkins: For making  available  the
  1549. source  code to Stella, another really great 2600 emulator.  This
  1550. has not been an isolated project, and I'd be lying if I said that
  1551. Stella  wasn't helpful. I certainly hope that PCAE's  source  has
  1552. been equally helpful.
  1553.  
  1554. A  lot  of others: Many of the features PCAE has today came  from
  1555. people who emailed me with their suggestions. This document is  a
  1556. direct  result of all the feedback I've gotten, and is my attempt
  1557. at making things clearer for everyone.
  1558.  
  1559. =================================================================
  1560. 8       Disclaimer
  1561.  
  1562. For  the  following  discussion,  this  software,  the  PC  Atari
  1563. Emulator, will be referred to as "PCAE".
  1564.  
  1565. The  author of PCAE hereby grants unlimited license for users  of
  1566. PCAE  to  freely copy and install it for personal  use.  PCAE  is
  1567. supplied as-is; the author WILL NOT be held responsible  for  ANY
  1568. damages  that  may occur as a direct or indirect  result  of,  or
  1569. inability  to use, PCAE. The author will not be held  responsible
  1570. for  damages  resulting from the loss of business or productivity
  1571. due  to the use of PCAE. Furthermore, the author will not be held
  1572. liable for any damages that may be incurred as a result of  using
  1573. non-standard video modes or hardware built for use with PCAE. The
  1574. author  also  cannot be held liable regarding the merchantability
  1575. (or  lack  thereof)  of  PCAE.  The  author  grants  no  warranty
  1576. whatsoever, and none should be implied.
  1577.  
  1578.                     USE IT AT YOUR OWN RISK.
  1579.  
  1580. As  stated previously, PCAE may be copied and distributed  freely
  1581. for  personal  use.  It MAY NOT be sold by anyone  without  prior
  1582. written consent by the author. It may be distributed as part of a
  1583. shareware/freeware package as long as not more than $7  US  (1996
  1584. dollars)  is  charged  for  its distribution.  PCAE  MAY  NOT  be
  1585. distributed without this document in its complete form. Any other
  1586. use of PCAE requires explicit written agreement from the author.
  1587.  
  1588. PCAE  emulates  a  commercial game system for  which  copyrighted
  1589. software  was  developed and still exists.  The  author  of  PCAE
  1590. hereby forbids anyone to distribute PCAE in conjunction with  any
  1591. other  copyrighted  software.  In addition,  users  of  PCAE  are
  1592. specifically forbidden from using it in any way with  copyrighted
  1593. software  for which they are not in legal ownership. PCAE  should
  1594. IN  NO WAY be regarded as condonation of, or an excuse to commit,
  1595. software piracy, and the author will not be held responsible  for
  1596. the actions of others.
  1597.  
  1598.